import java.util.HashMap;
import java.util.Map;
//和为k的子数组
public class leetcode560 {
    public int subarraySum(int[] nums, int k) {
        Map<Integer,Integer> map=new HashMap<>();
        int sum=0;
        int ret=0;
        map.put(0,1);
        for(int x:nums){
            sum+=x;
            ret+=map.getOrDefault(sum-k,0);
            map.put(sum,map.getOrDefault(sum,0)+1);
        }
        return ret;

    }
}
